home *** CD-ROM | disk | FTP | other *** search
/ Power Programmierung 2 / Power-Programmierung CD 2 (Tewi)(1994).iso / gnu / gnulib / dkbtrace / pbmplus / source / ppm / pgmtoppm.c < prev    next >
Encoding:
C/C++ Source or Header  |  1991-12-10  |  3.5 KB  |  150 lines

  1. /* pgmtoppm.c - colorize a portable graymap into a portable pixmap
  2. **
  3. ** Copyright (C) 1991 by Jef Poskanzer.
  4. **
  5. ** Permission to use, copy, modify, and distribute this software and its
  6. ** documentation for any purpose and without fee is hereby granted, provided
  7. ** that the above copyright notice appear in all copies and that both that
  8. ** copyright notice and this permission notice appear in supporting
  9. ** documentation.  This software is provided "as is" without express or
  10. ** implied warranty.
  11. */
  12.  
  13. #include "ppm.h"
  14.  
  15. void
  16. main( argc, argv )
  17.     int argc;
  18.     char* argv[];
  19.     {
  20.     FILE* ifp;
  21.     gray* grayrow;
  22.     register gray* gP;
  23.     pixel p;
  24.     pixel* pixelrow;
  25.     register pixel* pP;
  26.     pixel** mappixels;
  27.     int argn, rows, cols, format, maprows, mapcols, mapmaxcolor, row;
  28.     register int col;
  29.     gray maxval;
  30.     pixval mapmaxval;
  31.     char* color0;
  32.     char* color1;
  33.     pixval red0, grn0, blu0, red1, grn1, blu1;
  34.     char* usage = "<colorspec> [pgmfile]\n                 <colorspec1>,<colorspec2> [pgmfile]\n                 -map mapfile [pgmfile]";
  35.  
  36.     ppm_init( &argc, argv );
  37.  
  38.     argn = 1;
  39.     mappixels = (pixel**) 0;
  40.  
  41.     if ( argn < argc && argv[argn][0] == '-' && argv[argn][1] != '\0' )
  42.     {
  43.     if ( pm_keymatch( argv[argn], "-map", 2 ) )
  44.         {
  45.         ++argn;
  46.         if ( argn == argc )
  47.         pm_usage( usage );
  48.         ifp = pm_openr( argv[argn] );
  49.         mappixels = ppm_readppm( ifp, &mapcols, &maprows, &mapmaxval );
  50.         pm_close( ifp );
  51.         mapmaxcolor = maprows * mapcols - 1;
  52.         }
  53.     else
  54.         pm_usage( usage );
  55.     ++argn;
  56.     }
  57.  
  58.     if ( mappixels == (pixel**) 0 )
  59.     {
  60.     if ( argn == argc )
  61.         pm_usage( usage );
  62.     color0 = argv[argn];
  63.     ++argn;
  64.     }
  65.  
  66.     if ( argn != argc )
  67.     {
  68.     ifp = pm_openr( argv[argn] );
  69.     ++argn;
  70.     }
  71.     else
  72.     ifp = stdin;
  73.  
  74.     if ( argn != argc )
  75.     pm_usage( usage );
  76.  
  77.     pgm_readpgminit( ifp, &cols, &rows, &maxval, &format );
  78.     grayrow = pgm_allocrow( cols );
  79.     if ( mappixels == (pixel**) 0 )
  80.     ppm_writeppminit( stdout, cols, rows, (pixval) maxval, 0 );
  81.     else
  82.     ppm_writeppminit( stdout, cols, rows, mapmaxval, 0 );
  83.     pixelrow = ppm_allocrow( cols );
  84.  
  85.     if ( mappixels == (pixel**) 0 )
  86.     {
  87.     color1 = index( color0, '-' );
  88.     if ( color1 == 0 )
  89.         {
  90.         color1 = color0;
  91.         red0 = 0;
  92.         grn0 = 0;
  93.         blu0 = 0;
  94.         }
  95.     else
  96.         {
  97.         *color1 = '\0';
  98.         ++color1;
  99.         p = ppm_parsecolor( color0, (pixval) maxval );
  100.         red0 = PPM_GETR( p );
  101.         grn0 = PPM_GETG( p );
  102.         blu0 = PPM_GETB( p );
  103.         }
  104.     p = ppm_parsecolor( color1, (pixval) maxval );
  105.     red1 = PPM_GETR( p );
  106.     grn1 = PPM_GETG( p );
  107.     blu1 = PPM_GETB( p );
  108.     }
  109.  
  110.     for ( row = 0; row < rows; ++row )
  111.     {
  112.     pgm_readpgmrow( ifp, grayrow, cols, maxval, format );
  113.  
  114.     if ( mappixels == (pixel**) 0 )
  115.         {
  116.         for ( col = 0, gP = grayrow, pP = pixelrow;
  117.           col < cols;
  118.           ++col, ++gP, ++pP )
  119.         PPM_ASSIGN(
  120.             *pP,
  121.             ( red0 * ( maxval - *gP ) + red1 * *gP ) / maxval,
  122.             ( grn0 * ( maxval - *gP ) + grn1 * *gP ) / maxval,
  123.             ( blu0 * ( maxval - *gP ) + blu1 * *gP ) / maxval );
  124.  
  125.         }
  126.     else
  127.         {
  128.         register int c;
  129.  
  130.         for ( col = 0, gP = grayrow, pP = pixelrow;
  131.           col < cols;
  132.           ++col, ++gP, ++pP )
  133.         {
  134.         if ( maxval == mapmaxcolor )
  135.             c = *gP;
  136.         else
  137.             c = *gP * mapmaxcolor / maxval;
  138.         *pP = mappixels[c / mapcols][c % mapcols];
  139.         }
  140.         }
  141.  
  142.     ppm_writeppmrow( stdout, pixelrow, cols, (pixval) maxval, 0 );
  143.     }
  144.  
  145.     pm_close( ifp );
  146.     pm_close( stdout );
  147.  
  148.     exit( 0 );
  149.     }
  150.